



## IN THE UNITED STATES PATENT AND TRADEMARK OFFICE

Applicant(s): HIRAKO, et al.

Serial No.: 10/765,109

Filed: January 28, 2004

Title: A STORAGE DEVICE CONTROL APPARATUS AND A METHOD OF

CONTROLLING THE SAME

## LETTER CLAIMING RIGHT OF PRIORITY

Commissioner for Patents P.O. Box 1450 Alexandria, VA 22313-1450

February 25, 2004

Sir:

Under the provisions of 35 USC 119 and 37 CFR 1.55, the applicant(s) hereby claim(s) the right of priority based on:

Japanese Patent Application No. 2003-402996 Filed: December 2, 2003

A certified copy of said Japanese Patent Application is attached.

Respectfully submitted,

ANTONELLÍ, TERRY, STOUT & KRAUS, LLP

Carl I. Brundidge

Registration No.: 29,621

CIB/rr Attachment

# 日本国特許庁 JAPAN PATENT OFFICE

別紙添付の書類に記載されている事項は下記の出願書類に記載されている事項と同一であることを証明する。

This is to certify that the annexed is a true copy of the following application as filed with this Office.

出 願 年 月 日 Date of Application:

2003年12月 2日

出 願 番 号 Application Number:

特願2003-402996

[ST. 10/C]:

Applicant(s):

[JP2003-402996]

出 願 人

株式会社日立製作所

2004年 1月27日

特許庁長官 Commissioner, Japan Patent Office





ページ: 1/E

R A

【書類名】

特許願

【整理番号】

340301546

【提出日】

平成15年12月 2日

【あて先】

特許庁長官殿

【国際特許分類】

G06F 3/06

【発明者】

【住所又は居所】

神奈川県小田原市中里322番2号 株式会社日立製作所

IDシステム事業部内

【氏名】

平児 典夫

【特許出願人】

【識別番号】

000005108

【氏名又は名称】

株式会社日立製作所

【代理人】

【識別番号】

110000176

【氏名又は名称】

一色国際特許業務法人

【代表者】

一色 健輔

【手数料の表示】

【予納台帳番号】

211868

【納付金額】

21,000円

【提出物件の目録】

【物件名】

特許請求の範囲 1

【物件名】

明細書 1

【物件名】

図面 1

【物件名】

要約書 1

## 【書類名】特許請求の範囲

#### 【請求項1】

情報処理装置から記憶デバイスに対して送信されるデータ入出力要求を受信するチャネル制御部と、

前記記憶デバイスに対するデータ入出力に関する制御を行うディスク制御部と、

前記チャネル制御部と前記ディスク制御部との間で授受される入出力データを記憶する キャッシュメモリと、を備え、

前記チャネル制御部は、

前記情報処理装置との間で通信を行う通信インタフェース部と、

前記通信インタフェース部と第1のバスを介して接続し、前記通信インタフェース部と 前記キャッシュメモリとの間で授受される前記入出力データの転送を行うデータ転送部と

前記データ転送部と第2のバスを介して接続し、前記データ転送部の制御を行うプロセッサと、

#### を備え、

前記通信インタフェース部は、前記プロセッサに対して、データを読み出すことを指示する読み出しコマンドを前記データ転送部に送信し、

前記データ転送部は、前記第1のバスが第1の通信規約に従う場合、前記読み出しコマンドに応じた読み出しデータが後から送信されることを示すスプリット応答を前記通信インタフェース部に送信し、前記読み出しコマンドを前記プロセッサに送信し、

前記データ転送部は、前記第1のバスが第2の通信規約に従う場合、前記スプリット応答を前記通信インタフェース部に送信せずに、前記読み出しコマンドを前記プロセッサに送信し、

前記プロセッサは、前記読み出しコマンドを受信し、前記スプリット応答を前記データ 転送部に送信し、受信した前記読み出しコマンドに応じた前記読み出しデータを前記デー タ転送部に送信し、

前記データ転送部は、前記読み出しデータを受信し、受信した前記読み出しデータを前 記通信インタフェース部に送信すること、

を特徴とする記憶デバイス制御装置。

#### 【請求項2】

請求項1に記載の記憶デバイス制御装置であって、

前記第1の通信規約は、PCI-X規格であり、

前記第2の通信規約は、PCI規格であること、

を特徴とする記憶デバイス制御装置。

#### 【請求項3】

請求項1に記載の記憶デバイス制御装置であって、

前記データ転送部は、前記第1のバスが従う前記通信規約が前記第1の通信規約である か前記第2の通信規約であるかを示す情報を設定する通信規約設定部を備え、

前記データ転送部は、前記通信規約設定部に設定されている情報に応じて、前記通信インタフェース部に前記スプリット応答を送信するかどうかを決定すること、

を特徴とする記憶デバイス制御装置。

#### 【請求項4】

請求項1に記載の記憶デバイス制御装置であって、

前記プロセッサは、前記通信インタフェース部に対する前記読み出しコマンドを前記データ転送部に送信し、

前記データ転送部は、前記読み出しコマンドを受信し、前記スプリット応答を前記プロセッサに送信し、前記読み出しコマンドを前記通信インタフェース部に送信し、

前記通信インタフェース部は、前記読み出しコマンドに応じた前記読み出しデータを前記データ転送部に送信し、

前記データ転送部は、前記読み出しデータを受信し、受信した前記読み出しデータを前

記プロセッサに送信すること、

を特徴とする記憶デバイス制御装置。

#### 【請求項5】

請求項4に記載の記憶デバイス制御装置であって、

前記プロセッサは、前記第1のバスの使用権を獲得した後に、前記読み出しコマンドを 前記データ転送部に送信し、

前記プロセッサは、前記スプリット応答を受信し、前記第1のバスの前記使用権を解放し、

前記データ転送部は、前記第1のバスの前記使用権を獲得した後に、前記読み出しデータを前記プロセッサに送信し、前記読み出しデータを前記プロセッサに送信した後に、前記第1のバスの前記使用権を解放すること、

を特徴とする記憶デバイス制御装置。

### 【請求項6】

請求項1に記載の記憶デバイス制御装置であって、

前記チャネル制御部は、複数の前記通信インタフェースを備え、

第1の前記通信インタフェースは前記データ転送部と前記第1のバスで接続され、

前記チャネル制御部は、第2の前記通信インタフェースと前記データ転送部とを接続する第3のバスを備え、

前記プロセッサは、第1の前記通信インタフェース部に対する第1の前記読み出しコマンドを前記データ転送部に送信し、

前記データ転送部は、前記第1の読み出しコマンドを受信し、前記スプリット応答を前記プロセッサに送信し、前記第1の読み出しコマンドを前記第1の通信インタフェース部に送信し、

前記プロセッサは、第2の前記通信インタフェース部に対する第2の前記読み出しコマンドを前記データ転送部に送信し、

前記データ転送部は、前記第2の読み出しコマンドを受信し、前記スプリット応答を前記プロセッサに送信し、前記第2の読み出しコマンドを前記第2の通信インタフェース部に送信し、

前記第1の通信インタフェース部は、前記第1の読み出しコマンドに応じた第1の前記 読み出しデータを前記データ転送部に送信し、

前記データ転送部は、前記第1の読み出しデータを受信し、受信した前記第1の読み出 しデータを前記プロセッサに送信し、

前記第2の通信インタフェース部は、前記第2の読み出しコマンドに応じた第2の前記 読み出しデータを前記データ転送部に送信し、

前記データ転送部は、前記第2の読み出しデータを受信し、受信した前記第2の読み出 しデータを前記プロセッサに送信すること、

を特徴とする記憶デバイス制御装置。

## 【請求項7】

請求項1に記載の記憶デバイス制御装置であって、

前記チャネル制御部は、複数の前記通信インタフェースを備え、

第1の前記通信インタフェースは前記データ転送部と前記第1のバスで接続され、

前記チャネル制御部は、第2の前記通信インタフェースと前記データ転送部とを接続する第3のバスを備え、

前記データ転送部は、

前記第1のバスと接続し、前記第1の通信インタフェースとの間でデータの授受を行う 第1のバスインタフェース部と、

前記第2のバスと接続し、前記プロセッサとの間でデータの授受を行う第2のバスインタフェース部と、

前記第3のバスと接続し、前記第2の通信インタフェースとの間でデータの授受を行う 第3のバスインタフェース部と、 "を備え、

前記プロセッサは、前記第1の通信インタフェース部に対する第1の前記読み出しコマ ンドを前記データ転送部に送信し、

前記第2のバスインタフェース部は、前記第1の読み出しコマンドを受信し、受信した 前記第1の読み出しコマンドを前記第1のバスインタフェース部に送信し、前記スプリッ ト応答を前記プロセッサに送信し、

前記第1のバスインタフェース部は、受信した前記第1の読み出しコマンドを前記第1 の通信インタフェース部に送信し、

前記プロセッサは、第2の前記通信インタフェース部に対する第2の前記読み出しコマ ンドを前記データ転送部に送信し、

前記第2のバスインタフェース部は、前記第2の読み出しコマンドを受信し、受信した 前記第2の読み出しコマンドを前記第3のバスインタフェース部に送信し、前記スプリッ ト応答を前記プロセッサに送信し、

前記第3のバスインタフェース部は、受信した前記第2の読み出しコマンドを前記第2 の通信インタフェース部に送信し、

前記第1の通信インタフェース部は、前記第1の読み出しコマンドに応じた第1の前記 読み出しデータを前記データ転送部に送信し、

前記第1のバスインタフェース部は、前記第1の読み出しデータを受信し、受信した前 記第1の読み出しデータを前記第2のバスインタフェース部に送信し、前記第2のバスイ ンタフェース部は、受信した前記第1の読み出しデータを前記プロセッサに送信し、

前記第2の通信インタフェース部は、前記第2の読み出しコマンドに応じた第2の前記 読み出しデータを前記データ転送部に送信し、

前記第3のバスインタフェース部は、前記第2の読み出しデータを受信し、受信した前 記第2の読み出しデータを前記第2のバスインタフェース部に送信し、前記第2のバスイ ンタフェース部は、受信した前記第2の読み出しデータを前記プロセッサに送信すること

を特徴とする記憶デバイス制御装置。

#### 【請求項8】

請求項1に記載の記憶デバイス制御装置であって、

前記チャネル制御部は、複数の前記プロセッサを備え、

第1の前記プロセッサは、前記通信インタフェース部に対する第1の前記読み出しコマ ンドを前記データ転送部に送信し、

第2の前記プロセッサは、前記通信インタフェース部に対する第2の前記読み出しコマ ンドを前記データ転送部に送信し、

前記データ転送部は、前記第1及び第2の読み出しコマンドを受信し、前記第1及び第 2のプロセッサに前記スプリット応答を送信し、前記第1の読み出しコマンドを前記通信 インタフェース部に送信し、

前記通信インタフェース部は、前記第1の読み出しコマンドに応じて第1の前記読み出 しデータを前記データ転送部に送信し、

前記データ転送部は、前記第1の読み出しデータを前記第1のプロセッサに送信し、

前記通信インタフェース部は、前記第2の読み出しコマンドに応じて第2の前記読み出 しデータを前記データ転送部に送信し、

前記データ転送部は、前記第2の読み出しデータを前記第2のプロセッサに送信するこ と、

を特徴とする記憶デバイス制御装置。

#### 【請求項9】

請求項8に記載の記憶デバイス制御装置であって、

前記データ転送部は、前記第1及び第2の読み出しコマンドを受信し、前記第1又は第 2のコマンドのうち先に受信したものを先に前記通信インタフェース部に送信すること、 を特徴とする記憶デバイス制御装置。

## 【請求項10】

請求項1に記載の記憶デバイス制御装置であって、

前記チャネル制御部は複数の前記通信インタフェース部と、複数の前記プロセッサとを 備え、

前記チャネル制御部は、

第1の前記通信インタフェース部と前記データ転送装置とを接続する第1のバスと、

第1の前記プロセッサと前記データ転送装置とを接続する第2のバスと、

第2の前記通信インタフェース部と前記データ転送装置とを接続する第3のバスと、

第2の前記プロセッサと前記データ転送装置とを接続する第4のバスと、

を備え、

前記データ転送部は、

前記第1にバスに接続し、前記第1の通信インタフェース部との間でデータを授受する 第1のバスブリッジと、

前記第2のバスに接続し、前記第1のプロセッサとの間でデータを授受する第2のバスブリッジと、

前記第3のバスに接続し、前記第2の通信インタフェース部との間でデータを授受する 第3のバスブリッジと、

前記第4のバスに接続し、前記第2のプロセッサとの間でデータを授受する第4のバスブリッジと、

を備え、

前記第2のバスブリッジは、前記第1のバスブリッジと前記第3のバスブリッジとに接続し、

前記第4のバスブリッジは、前記第1のバスブリッジと前記第3のバスブリッジとに接続すること、

を特徴とする記憶デバイス制御装置。

## 【請求項11】

請求項10に記載の記憶デバイス制御装置であって、

前記第1のプロセッサは、前記第2のバスの使用権を獲得し、前記第1の通信インタフェース部に対する、データの読み出しを指示する第1の読み出しコマンドを前記データ転送部に送信し、

前記第2のバスブリッジは、前記第1の読み出しコマンドを受信し、第1の前記スプリット応答を前記第1のプロセッサに送信し、受信した前記第1の読み出しコマンドを前記第1のバスブリッジに転送し、

前記第1のプロセッサは、前記第1のスプリット応答を受信し、前記第1のバスの前記 使用権を解放し、

前記第1のバスブリッジは、前記第1の読み出しコマンドを受信し、前記第1の読み出しコマンドを前記第1の通信インタフェース部に送信し、

前記第1のプロセッサは、前記第1のバスの前記使用権を獲得し、前記第2の通信インタフェース部に対する第2の読み出しコマンドを前記データ転送部に送信し、

前記第2のバスブリッジは、前記第2の読み出しコマンドを受信し、第2の前記スプリット応答を前記第1のプロセッサに送信し、受信した前記第2の読み出しコマンドを前記第3のバスブリッジに転送し、

前記第1のプロセッサは、前記第2のスプリット応答を受信し、前記第1のバスの前記 使用権を解放し、

前記第1の通信インタフェース部は、前記第1の読み出しコマンドに応じた第1の前記 読み出しデータを前記データ転送部に送信し、

前記第1のバスブリッジは、前記第1の読み出しデータを受信し、受信した前記第1の 読み出しデータを前記第2のバスブリッジに転送し、

前記第2のバスブリッジは、前記第1のバスの前記使用権を獲得し、前記第1の読み出しデータを前記第1のプロセッサに送信し、前記第1のバスの前記使用権を解放し、

が前記第2の通信インタフェース部は、前記第2の読み出しコマンドに応じた第2の前記読み出しデータを前記データ転送部に送信し、

前記第3のバスブリッジは、前記第2の読み出しデータを受信し、受信した前記第2の 読み出しデータを前記第2のバスブリッジに転送し、

前記第2のバスブリッジは、前記第1のバスの前記使用権を獲得し、前記第2の読み出しデータを前記第1のプロセッサに送信すること、

を特徴とする記憶デバイス制御装置。

#### 【請求項12】

請求項10に記載の記憶デバイス制御装置であって、

前記第1のプロセッサは、前記第1の通信インタフェース部に対する第1の読み出しコマンドを前記データ転送部に送信し、

前記第2のプロセッサは、前記第1の通信インタフェース部に対する第2の読み出しコマンドを前記データ転送部に送信し、

前記第2のバスブリッジは、前記第1の読み出しコマンドを受信し、前記第1の読み出しコマンドを前記第1のバスブリッジに転送し、前記第1のプロセッサに前記スプリット応答を送信し、

前記第1のバスブリッジは、前記第2の読み出しコマンドを受信し、前記第2の読み出しコマンドを前記第1の通信インタフェース部に送信し、

前記第4のバスブリッジは、前記第2の読み出しコマンドを受信し、前記第2の読み出しコマンドを前記第1のバスブリッジに転送し、前記第2のプロセッサに前記スプリット応答を送信し、

前記第1のバスブリッジは、前記第2の読み出しコマンドを受信し、

前記第1のバスブリッジは、前記第1の読み出しコマンドに応じた第1の読み出しデータを前記第1の通信インタフェース部から受信し、受信した前記第1の読み出しデータを前記第2のバスブリッジに転送し、

前記第1のバスブリッジは、前記第2の読み出しコマンドを前記第1の通信インタフェース部に送信し、

前記第2のバスブリッジは、前記第1の読み出しデータを受信し、受信した前記第1の 読み出しデータを前記第1のプロセッサに送信し、

前記第1のバスブリッジは、前記第2の読み出しコマンドに応じた第2の読み出しデータを前記第1の通信インタフェース部から受信し、受信した前記第2の読み出しデータを前記第4のバスブリッジに転送し、

前記第4のバスブリッジは、前記第2の読み出しデータを前記第2のプロセッサに送信すること、

を特徴とする記憶デバイス制御装置。

#### 【請求項13】

情報処理装置から記憶デバイスに対して送信されるデータ入出力要求を受信するチャネル制御部と、

前記記憶デバイスに対するデータ入出力に関する制御を行うディスク制御部と、

前記チャネル制御部と前記ディスク制御部との間で授受される入出力データを記憶する キャッシュメモリと、を備え、

前記チャネル制御部は、

前記情報処理装置との間で通信を行う通信インタフェース部と、

前記通信インタフェース部と第1のバスを介して接続し、前記通信インタフェース部と 前記キャッシュメモリとの間で授受される前記入出力データの転送を行うデータ転送部と

前記データ転送部と第2のバスを介して接続し、前記データ転送部の制御を行うプロセッサと、

を備える記憶デバイス制御装置の制御方法であって、

前記通信インタフェース部は、前記プロセッサに対して、データを読み出すことを指示

出証特2004-3003014

ずる読み出しコマンドを前記データ転送部に送信し、

前記データ転送部は、前記第1のバスが第1の通信規約に従う場合、前記読み出しコマンドに応じた読み出しデータが後から送信されることを示すスプリット応答を前記通信インタフェース部に送信し、前記読み出しコマンドを前記プロセッサに送信し、

前記データ転送部は、前記第1のバスが第2の通信規約に従う場合、前記スプリット応答を前記通信インタフェース部に送信せずに、前記読み出しコマンドを前記プロセッサに送信し、

前記プロセッサは、前記読み出しコマンドを受信し、前記スプリット応答を前記データ 転送部に送信し、受信した前記読み出しコマンドに応じた前記読み出しデータを前記デー タ転送部に送信し、

前記データ転送部は、前記読み出しデータを受信し、受信した前記読み出しデータを前記通信インタフェース部に送信すること、

を特徴とする記憶デバイス制御装置の制御方法。

## 【請求項14】

請求項13に記載の記憶デバイス制御装置の制御方法であって、

前記プロセッサは、前記通信インタフェース部に対する前記読み出しコマンドを前記データ転送部に送信し、

前記データ転送部は、前記読み出しコマンドを受信し、前記スプリット応答を前記プロセッサに送信し、前記読み出しコマンドを前記通信インタフェース部に送信し、

前記通信インタフェース部は、前記読み出しコマンドに応じた前記読み出しデータを前記データ転送部に送信し、

前記データ転送部は、前記読み出しデータを受信し、受信した前記読み出しデータを前記プロセッサに送信すること、

を特徴とする記憶デバイス制御装置の制御方法。

#### 【請求項15】

請求項13に記載の記憶デバイス制御装置の制御方法であって、

前記チャネル制御部は、複数の前記通信インタフェースを備え、

第1の前記通信インタフェースは前記データ転送部と前記第1のバスで接続され、

前記チャネル制御部は、第2の前記通信インタフェースと前記データ転送部とを接続する第3のバスを備え、

前記プロセッサは、第1の前記通信インタフェース部に対する第1の前記読み出しコマンドを前記データ転送部に送信し、

前記データ転送部は、前記第1の読み出しコマンドを受信し、前記スプリット応答を前記プロセッサに送信し、前記第1の読み出しコマンドを前記第1の通信インタフェース部に送信し、

前記プロセッサは、第2の前記通信インタフェース部に対する第2の前記読み出しコマンドを前記データ転送部に送信し、

前記データ転送部は、前記第2の読み出しコマンドを受信し、前記スプリット応答を前記プロセッサに送信し、前記第2の読み出しコマンドを前記第2の通信インタフェース部に送信し、

前記第1の通信インタフェース部は、前記第1の読み出しコマンドに応じた第1の前記 読み出しデータを前記データ転送部に送信し、

前記データ転送部は、前記第1の読み出しデータを受信し、受信した前記第1の読み出 しデータを前記プロセッサに送信し、

前記第2の通信インタフェース部は、前記第2の読み出しコマンドに応じた第2の前記 読み出しデータを前記データ転送部に送信し、

前記データ転送部は、前記第2の読み出しデータを受信し、受信した前記第2の読み出 しデータを前記プロセッサに送信すること、

を特徴とする記憶デバイス制御装置の制御方法。

#### 【請求項16】

「請求項13に記載の記憶デバイス制御装置であって、

前記チャネル制御部は、複数の前記通信インタフェースを備え、

第1の前記通信インタフェースは前記データ転送部と前記第1のバスで接続され、

前記チャネル制御部は、第2の前記通信インタフェースと前記データ転送部とを接続する第3のバスを備え、

前記データ転送部は、

前記第1のバスと接続し、前記第1の通信インタフェースとの間でデータの授受を行う 第1のバスインタフェース部と、

前記第2のバスと接続し、前記プロセッサとの間でデータの授受を行う第2のバスインタフェース部と、

前記第3のバスと接続し、前記第2の通信インタフェースとの間でデータの授受を行う 第3のバスインタフェース部と、

を備え、

前記プロセッサは、前記第1の通信インタフェース部に対する第1の前記読み出しコマンドを前記データ転送部に送信し、

前記第2のバスインタフェース部は、前記第1の読み出しコマンドを受信し、受信した前記第1の読み出しコマンドを前記第1のバスインタフェース部に送信し、前記スプリット応答を前記プロセッサに送信し、

前記第1のバスインタフェース部は、受信した前記第1の読み出しコマンドを前記第1 の通信インタフェース部に送信し、

前記プロセッサは、第2の前記通信インタフェース部に対する第2の前記読み出しコマンドを前記データ転送部に送信し、

前記第2のバスインタフェース部は、前記第2の読み出しコマンドを受信し、受信した前記第2の読み出しコマンドを前記第3のバスインタフェース部に送信し、前記スプリット応答を前記プロセッサに送信し、

前記第3のバスインタフェース部は、受信した前記第2の読み出しコマンドを前記第2の通信インタフェース部に送信し、

前記第1の通信インタフェース部は、前記第1の読み出しコマンドに応じた第1の前記 読み出しデータを前記データ転送部に送信し、

前記第1のバスインタフェース部は、前記第1の読み出しデータを受信し、受信した前記第1の読み出しデータを前記第2のバスインタフェース部に送信し、前記第2のバスインタフェース部は、受信した前記第1の読み出しデータを前記プロセッサに送信し、

前記第2の通信インタフェース部は、前記第2の読み出しコマンドに応じた第2の前記 読み出しデータを前記データ転送部に送信し、

前記第3のバスインタフェース部は、前記第2の読み出しデータを受信し、受信した前記第2の読み出しデータを前記第2のバスインタフェース部に送信し、前記第2のバスインタフェース部は、受信した前記第2の読み出しデータを前記プロセッサに送信すること

を特徴とする記憶デバイス制御装置の制御方法。

#### 【請求項17】

請求項13に記載の記憶デバイス制御装置の制御方法であって、

前記チャネル制御部は、複数の前記プロセッサを備え、

第1の前記プロセッサは、前記通信インタフェース部に対する第1の前記読み出しコマンドを前記データ転送部に送信し、

第2の前記プロセッサは、前記通信インタフェース部に対する第2の前記読み出しコマンドを前記データ転送部に送信し、

前記データ転送部は、前記第1及び第2の読み出しコマンドを受信し、前記第1及び第2のプロセッサに前記スプリット応答を送信し、前記第1の読み出しコマンドを前記通信インタフェース部に送信し、

前記通信インタフェース部は、前記第1の読み出しコマンドに応じて第1の前記読み出

じデータを前記データ転送部に送信し、

前記データ転送部は、前記第1の読み出しデータを前記第1のプロセッサに送信し、 前記通信インタフェース部は、前記第2の読み出しコマンドに応じて第2の前記読み出 しデータを前記データ転送部に送信し、

前記データ転送部は、前記第2の読み出しデータを前記第2のプロセッサに送信すること、

を特徴とする記憶デバイス制御装置の制御方法。

#### 【請求項18】

請求項17に記載の記憶デバイス制御装置の制御方法であって、

前記データ転送部は、前記第1及び第2の読み出しコマンドを受信し、前記第1又は第2のコマンドのうち先に受信したものを先に前記通信インタフェース部に送信すること、 を特徴とする記憶デバイス制御装置の制御方法。

#### 【請求項19】

請求項13に記載の記憶デバイス制御装置の制御方法であって、

前記チャネル制御部は複数の前記通信インタフェース部と、複数の前記プロセッサとを 備え、

前記チャネル制御部は、

第1の前記通信インタフェース部と前記データ転送装置とを接続する第1のバスと、

第1の前記プロセッサと前記データ転送装置とを接続する第2のバスと、

第2の前記通信インタフェース部と前記データ転送装置とを接続する第3のバスと、

第2の前記プロセッサと前記データ転送装置とを接続する第4のバスと、

を備え、

前記データ転送部は、

前記第1にバスに接続し、前記第1の通信インタフェース部との間でデータを授受する 第1のバスブリッジと、

前記第2のバスに接続し、前記第1のプロセッサとの間でデータを授受する第2のバスブリッジと、

前記第3のバスに接続し、前記第2の通信インタフェース部との間でデータを授受する 第3のバスブリッジと、

前記第4のバスに接続し、前記第2のプロセッサとの間でデータを授受する第4のバスブリッジと、

を備え、

前記第2のバスブリッジは、前記第1のバスブリッジと前記第3のバスブリッジとに接続し、

前記第4のバスブリッジは、前記第1のバスブリッジと前記第3のバスブリッジとに接続し、

前記第1のプロセッサは、前記第2のバスの使用権を獲得し、前記第1の通信インタフェース部に対する、データの読み出しを指示する第1の読み出しコマンドを前記データ転送部に送信し、

前記第2のバスブリッジは、前記第1の読み出しコマンドを受信し、第1の前記スプリット応答を前記第1のプロセッサに送信し、受信した前記第1の読み出しコマンドを前記第1のバスブリッジに転送し、

前記第1のプロセッサは、前記第1のスプリット応答を受信し、前記第1のバスの前記 使用権を解放し、

前記第1のバスブリッジは、前記第1の読み出しコマンドを受信し、前記第1の読み出しコマンドを前記第1の通信インタフェース部に送信し、

前記第1のプロセッサは、前記第1のバスの前記使用権を獲得し、前記第2の通信インタフェース部に対する第2の読み出しコマンドを前記データ転送部に送信し、

前記第2のバスブリッジは、前記第2の読み出しコマンドを受信し、第2の前記スプリット応答を前記第1のプロセッサに送信し、受信した前記第2の読み出しコマンドを前記

第3のバスブリッジに転送し、

前記第1のプロセッサは、前記第2のスプリット応答を受信し、前記第1のバスの前記 使用権を解放し、

前記第1の通信インタフェース部は、前記第1の読み出しコマンドに応じた第1の前記 読み出しデータを前記データ転送部に送信し、

前記第1のバスブリッジは、前記第1の読み出しデータを受信し、受信した前記第1の 読み出しデータを前記第2のバスブリッジに転送し、

前記第2のバスブリッジは、前記第1のバスの前記使用権を獲得し、前記第1の読み出しデータを前記第1のプロセッサに送信し、前記第1のバスの前記使用権を解放し、

前記第2の通信インタフェース部は、前記第2の読み出しコマンドに応じた第2の前記 読み出しデータを前記データ転送部に送信し、

前記第3のバスブリッジは、前記第2の読み出しデータを受信し、受信した前記第2の 読み出しデータを前記第2のバスブリッジに転送し、

前記第2のバスブリッジは、前記第1のバスの前記使用権を獲得し、前記第2の読み出しデータを前記第1のプロセッサに送信すること、

を特徴とする記憶デバイス制御装置の制御方法。

## 【請求項20】

請求項13に記載の記憶デバイス制御装置の制御方法であって、

前記チャネル制御部は複数の前記通信インタフェース部と、複数の前記プロセッサとを 備え、

前記チャネル制御部は、

第1の前記通信インタフェース部と前記データ転送装置とを接続する第1のバスと、

第1の前記プロセッサと前記データ転送装置とを接続する第2のバスと、

第2の前記通信インタフェース部と前記データ転送装置とを接続する第3のバスと、

第2の前記プロセッサと前記データ転送装置とを接続する第4のバスと、

を備え、

前記データ転送部は、

前記第1にバスに接続し、前記第1の通信インタフェース部との間でデータを授受する 第1のバスブリッジと、

前記第2のバスに接続し、前記第1のプロセッサとの間でデータを授受する第2のバスブリッジと、

前記第3のバスに接続し、前記第2の通信インタフェース部との間でデータを授受する 第3のバスブリッジと、

前記第4のバスに接続し、前記第2のプロセッサとの間でデータを授受する第4のバスブリッジと、

を備え、

前記第2のバスブリッジは、前記第1のバスブリッジと前記第3のバスブリッジとに接続し、

前記第4のバスブリッジは、前記第1のバスブリッジと前記第3のバスブリッジとに接続し、

前記第1のプロセッサは、前記第1の通信インタフェース部に対する第1の読み出しコマンドを前記データ転送部に送信し、

前記第2のプロセッサは、前記第1の通信インタフェース部に対する第2の読み出しコマンドを前記データ転送部に送信し、

前記第2のバスブリッジは、前記第1の読み出しコマンドを受信し、前記第1の読み出しコマンドを前記第1のバスブリッジに転送し、前記第1のプロセッサに前記スプリット応答を送信し、

前記第1のバスブリッジは、前記第2の読み出しコマンドを受信し、前記第2の読み出 しコマンドを前記第1の通信インタフェース部に送信し、

前記第4のバスブリッジは、前記第2の読み出しコマンドを受信し、前記第2の読み出

じコマンドを前記第1のバスブリッジに転送し、前記第2のプロセッサに前記スプリット 応答を送信し、

前記第1のバスブリッジは、前記第2の読み出しコマンドを受信し、

前記第1のバスブリッジは、前記第1の読み出しコマンドに応じた第1の読み出しデータを前記第1の通信インタフェース部から受信し、受信した前記第1の読み出しデータを前記第2のバスブリッジに転送し、

前記第1のバスブリッジは、前記第2の読み出しコマンドを前記第1の通信インタフェース部に送信し、

前記第2のバスブリッジは、前記第1の読み出しデータを受信し、受信した前記第1の 読み出しデータを前記第1のプロセッサに送信し、

前記第1のバスブリッジは、前記第2の読み出しコマンドに応じた第2の読み出しデータを前記第1の通信インタフェース部から受信し、受信した前記第2の読み出しデータを前記第4のバスブリッジに転送し、

前記第4のバスブリッジは、前記第2の読み出しデータを前記第2のプロセッサに送信すること、

を特徴とする記憶デバイス制御装置の制御方法。

## 【書類名】明細書

【発明の名称】記憶デバイス制御装置及び記憶デバイス制御装置の制御方法

## 【技術分野】

 $[0\ 0\ 0\ 1]$ 

本発明は、記憶デバイス制御装置及び記憶デバイス制御装置の制御方法に関する。

## 【背景技術】

 $[0\ 0\ 0\ 2]$ 

近年情報処理装置で取り扱われるデータ量が増加しており、情報処理装置外部でデータを記憶・管理するストレージ装置では、より大容量かつより高速であることが求められている。

【特許文献1】特開2003-91497号公報

## 【発明の開示】

【発明が解決しようとする課題】

[0003]

このような状況の下、ストレージ装置の設計においては、新たな規格を柔軟かつ積極的に取り込みつつデータ転送処理効率を向上させることが求められている。

#### $[0\ 0\ 0\ 4\ ]$

本発明は、このような背景を鑑みてなされたものであり、新たな規格を柔軟かつ積極的 に取り込みつつデータ転送処理効率を向上した記憶デバイス制御装置及び記憶デバイス制御装置の制御方法提供することを目的とする。

#### 【課題を解決するための手段】

#### [0005]

上記目的を達成するための本発明のうち主たる発明のひとつは、記憶デバイス制御装置 であって、情報処理装置から記憶デバイスに対して送信されるデータ入出力要求を受信す るチャネル制御部と、前記記憶デバイスに対するデータ入出力に関する制御を行うディス ク制御部と、前記チャネル制御部と前記ディスク制御部との間で授受される入出力データ を記憶するキャッシュメモリと、を備え、前記チャネル制御部は、前記情報処理装置との 間で通信を行う通信インタフェース部と、前記通信インタフェース部と第1のバスを介し て接続し、前記通信インタフェース部と前記キャッシュメモリとの間で授受される前記入 出力データの転送を行うデータ転送部と、前記データ転送部と第2のバスを介して接続し 、前記データ転送部の制御を行うプロセッサと、を備え、前記通信インタフェース部は、 前記プロセッサに対して、データを読み出すことを指示する読み出しコマンドを前記デー 夕転送部に送信し、前記データ転送部は、前記第1のバスが第1の通信規約に従う場合、 前記読み出しコマンドに応じた読み出しデータが後から送信されることを示すスプリット 応答を前記通信インタフェース部に送信し、前記読み出しコマンドを前記プロセッサに送 信し、前記データ転送部は、前記第1のバスが第2の通信規約に従う場合、前記スプリッ ト応答を前記通信インタフェース部に送信せずに、前記読み出しコマンドを前記プロセッ サに送信し、前記プロセッサは、前記読み出しコマンドを受信し、前記スプリット応答を 前記データ転送部に送信し、受信した前記読み出しコマンドに応じた前記読み出しデータ を前記データ転送部に送信し、前記データ転送部は、前記読み出しデータを受信し、受信 した前記読み出しデータを前記通信インタフェース部に送信することとする。

#### 【発明の効果】

[0006]

本発明によれば、新たな規格を柔軟かつ積極的に取り込みつつデータ転送処理効率を向上した記憶デバイス制御装置及び記憶デバイス制御装置の制御方法を提供できる。

【発明を実施するための最良の形態】

[0007]

以下、本発明の実施形態の一例を図面を用いて詳細に説明する。

#### [0008]

===ストレージシステム全体像===

\*図1は、本発明を適用した記憶デバイス制御装置200を含む情報処理システムの全体 構成を示すブロック図である。図1に示すように、ストレージシステムは、各種の情報処 理サービスを提供する情報処理装置100と、記憶ボリューム300の記憶領域を情報処 理装置100に提供する記憶デバイス制御装置200とを含んで構成される。

#### [0009]

情報処理装置100はCPU (Central Processing Unit) やメモリを備えたコンピュ ータである。情報処理装置100では、CPUにより各種のプログラムが実行され、様々 な機能が実現される。情報処理装置100は、例えば、パーソナルコンピュータやワーク ステーション、メインフレームコンピュータなどである。情報処理装置100は1台のコ ンピュータであってもよいし、複数台のコンピュータであってもよい。情報処理装置10 0上ではオペレーティングシステムが実行され、オペレーティングシステム上では様々な アプリケーションプログラムが実行される。

## $[0\ 0\ 1\ 0\ ]$

情報処理装置100は、SAN (Storage Area Network) 400を介して記憶デバイス 制御装置200と接続されている。SAN400を介して行われる情報処理装置100と 記憶デバイス制御装置200との間の通信はファイバチャネルプロトコルに従って行われ る。SAN400はファイバチャネルプロトコル以外にもさまざまなプロトコルに従った 通信経路とすることもできる。SAN400には、例えば、LAN(Local Area Network ) やSCSI (Small Computer System Interface) 、iSCSI (Internet Small Comp uter System Interface)、ESCON (Enterprise System Connection) (登録商標) 、FICON (Fibre Connection) (登録商標)、ACONARC (Advanced Connection n Architecture) (登録商標)、FIBARC (Fibre connection Architecture) (登 録商標)などを用いることができる。なお、情報処理装置100と記憶デバイス制御装置 200とは直接接続する形態としてもよい。

## $[0\ 0\ 1\ 1\ ]$

情報処理装置100はファイバチャネルプロトコルに従って、データ入出力要求を記憶 デバイス制御装置200に送信する。記憶デバイス制御装置200は、情報処理装置10 0からデータ入出力要求を受信すると、受信したデータ入出力要求に応じて、記憶ボリュ ーム300に対するデータの入出力に関する処理を行う。このようにして、情報処理装置 100上で実行されるアプリケーションプログラムは、記憶ボリューム300の記憶領域 に適宜アクセスしながら各種処理を実行する。

## $[0\ 0\ 1\ 2]$

記憶デバイス制御装置200は多数の物理ディスクを備え、複数の記憶ボリューム30 0の提供する記憶領域を管理している。記憶ボリューム(記憶デバイス)300とは、物 理ディスクにより提供される物理ボリュームと、物理ボリューム上に論理的に設定される 論理ボリュームとを含む記憶領域である。物理ディスクとしては、例えば、ハードディス ク装置や半導体記憶装置等を用いることができる。記憶デバイス制御装置200は、複数 の記憶ボリューム300によってディスクアレイを構成し、RAIDによって管理される 記憶領域を提供することもできるし、単一の物理ディスクによる記憶領域を提供するよう にもできる。記憶ボリューム300は記憶デバイス制御装置200に一体的に構成されて もよいし、記憶デバイス制御装置200から独立した装置として、SCSIやLAN、S ANといった通信経路によって記憶デバイス制御装置200と接続する形態としてもよい

#### $[0\ 0\ 1\ 3]$

図1に示すように、記憶デバイス制御装置200は、チャネル制御部1乃至3(210 )、共有メモリ220、キャッシュメモリ230、ディスク制御部1乃至3(240)、 接続部250を備える。

#### $[0\ 0\ 1\ 4]$

チャネル制御部210は情報処理装置100との間で通信を行うための通信インタフェ ースを備え、情報処理装置100から記憶デバイスに対して送信されるデータ入出力要求 

## $[0\ 0\ 1\ 5]$

接続部250はチャネル制御部210、共有メモリ220、キャッシュメモリ230、ディスク制御部240を相互に接続する。チャネル制御部210、共有メモリ220、キャッシュメモリ230、ディスク制御部240間でのデータやコマンドの授受は接続部250を介して行われる。接続部250は、例えば、高速スイッチングによりデータ伝送を行う高速クロスバスイッチなどの高速バスである。

## [0016]

共有メモリ220及びキャッシュメモリ230は、チャネル制御部210やディスク制御部240により共有される記憶メモリである。共有メモリ220は主に制御情報やコマンド等を記憶するために利用されるのに対し、キャッシュメモリ230は主にデータを記憶するために利用される。チャネル制御部210は生成したI/Oコマンドを共有メモリ220に書き込む。チャネル制御部210は、例えば書き込みデータ等のI/Oコマンドに付随するデータはキャッシュメモリ230に書き込む。

## $[0\ 0\ 1\ 7]$

ディスク制御部240は記憶ボリューム300に対するデータ入出力に関する制御を行う。ディスク制御部240は、共有メモリ220に書き込まれたI/Oコマンドを読み出し、I/Oコマンドに従って記憶ボリューム300へデータの入出力に関する制御を行う。また、ディスク制御部240は、チャネル制御部210がI/Oコマンドに指定した論理アドレスを物理アドレスに変換する。また、ディスク制御部240は、記憶ボリューム300における物理ディスクがRAIDにより管理されている場合に、RAID構成(例えば、RAID0,1,5)に従ったデータのアクセスを行う。

## [0018]

例えば、チャネル制御部210は、情報処理装置100から受信したデータ入出力要求がデータの読み出し要求である場合には、読み出し対象となるデータがキャッシュメモリ230に存在するかどうかを調べる。読み出し対象となるデータがキャッシュメモリ230に存在すれば、チャネル制御部210はそのデータを情報処理装置100に送信する。一方、読みだし対象となるデータがキャッシュメモリ230に存在しない場合には、チャネル制御部210は読み出しコマンドを共有メモリ220に書き込むと共に、共有メモリ220に書き込まれたことを検出したディスク制御部240は、記憶ボリューム300から読みだし対象となるデータを読み出してこれをキャッシュメモリ230に書き込む。チャネル制御部210は読みだし対象となるデータがキャッシュメモリ230に書き込む。チャネル制御部210は読みだし対象となるデータがキャッシュメモリ230に書き込まれたことを検出すると、そのデータを情報処理装置100に送信する。

このようにチャネル制御部210及びディスク制御部240の間では、キャッシュメモリ230を介してデータの授受が行われる。

#### [0019]

## ===チャネル制御部===

図2は、チャネル制御部210の内部構成を示す図である。

## [0020]

マイクロプロセッサ (MP) 1及び2 (211) (第1のプロセッサ及び第2のプロセッサ)、ローカルメモリ1及び2 (212)、通信インタフェース (PRTCL) 1及び2 (213) (第1の通信インタフェース部及び第2の通信インタフェース部)、データ

パッファ214、接続コネクタ217、データ転送LSI500 (データ転送部) を備える。

## [0021]

通信インタフェース1 (213) とデータ転送LSI500とは、バス2103 (第1のバス) により接続されている。マイクロプロセッサ1 (211) とデータ転送LSI500とは、バス2101 (第2にバス) により接続されている。

## [0022]

また、通信インタフェース2(213)とデータ転送LSI500とはバス2104(第3のバス)により接続されている。マイクロプロセッサ2(211)とデータ転送LSI500とは、バス2102(第4のバス)により接続されている。本実施の形態において、バス2101及び2102はPCI-X規格に従うバスであるものとする。また、バス2103及び2104はPCI規格に従うバスであるものとする。

#### [0023]

通信インタフェース 2 1 3 は、情報処理装置 1 0 0 との間で通信を行うためのインタフェースを備えている。通信コネクタ 2 1 6 は情報処理装置 1 0 0 と通信を行うためのコネクタである。本実施の形態におけるチャネル制御部 2 1 0 の場合、通信コネクタ 2 1 6 は、SAN 4 0 0 に接続可能なコネクタであり、例えば、ファイバチャネルに対応している。チャネル制御部 2 1 0 が情報処理装置 1 0 0 からファイル名を指定したデータ入出力要求を受け付けるのであれば、通信コネクタは例えばイーサネット(登録商標)に対応し、チャネル制御部 2 1 0 は L A N 経由でデータ入出力要求を受け付けるようにしてもよい。

## [0024]

マイクロプロセッサ211はチャネル制御部210全体の制御を司る。マイクロプロセッサ211がローカルメモリ212に記憶されたアプリケーションプログラムを実行することによって、各種の機能が実現する。

## [0025]

接続コネクタ217はチャネル制御部210が記憶デバイス制御装置200と接続するためのコネクタである。接続コネクタ217が記憶デバイス制御装置200側のコネクタと嵌合することにより、チャネル制御部210のボードは記憶デバイス制御装置200と電気的に接続される。チャネル制御部210は接続コネクタ217を介して接続部250に接続され、記憶デバイス制御装置200内の共有メモリ220やキャッシュメモリ230、ディスク制御部240などにアクセスが可能となっている。

### [0026]

データ転送LSI500は、マイクロプロセッサ211からの指示により、デバイス間でのデータの転送を行う装置である。データ転送LSI500はPCIバス及びPCI- Xバスのマスタ(イニシエータ)として、バス2101乃至2104にデータを送出することができる。また、バス2101乃至2104に接続しているマイクロプロセッサ21 1 や通信インタフェース213等のデバイスからコマンドを受信するターゲットデバイス としても動作することができる。データ転送LSI500は、マイクロプロセッサ211 からコマンドを受信すると、そのコマンドに対する応答が後から送信されることを示すスプリット応答をマイクロプロセッサ211に返信することができる。これにより、イニシエータがターゲットへコマンドを送信するサイクルと、ターゲットがイニシエータへ応答を返信するサイクルとを別サイクルとする、いわゆるスプリットトランザクションが実現される。PCI-X規格では上記のスプリットトランザクションが規定されており、バス2101及び2102はPCI-X規格に従うバスであるため、データ転送LSI500はマイクロプロセッサ1及び2(211)との間でスプリットトランザクションを実現することができ、バスの使用効率を向上することができる。

#### [0027]

また、図2に示すように、データ転送LSI500は、バス間を接続するための4つのブリッジ(ブリッジA501、ブリッジB502、ブリッジC503、及びブリッジD504)、データバッファ2に対するアクセスを行うバッファコントローラ(BUFCTL

) 505、モードセレクタ506を備える。

## [0028]

ブリッジC503 (第1のバスブリッジ、第1のバスインタフェース)、ブリッジA501 (第2のバスブリッジ、第2のバスインタフェース)、ブリッジD504 (第3のバスブリッジ、第3のバスインタフェース)、ブリッジB502 (第4のバスブリッジ、第4のバスインタフェース)はいずれも、バス間のデータを転送するための装置である。

ブリッジA501は、バス2101に接続している。ブリッジA501は、バス2101を介してマイクロプロセッサ1(211)との間でデータのやりとりを行う。ブリッジB502は、バス2102を介してマイクロプロセッサ2(211)との間でデータのやりとりを行う。

ブリッジC503は、バス2103に接続している。ブリッジC503は、バス2103を介して通信インタフェース1(213)との間でデータのやりとりを行う。ブリッジD504は、バス2104を介して通信インタフェース2(213)との間でデータのやりとりを行う。

## [0029]

モードセレクタ506は、データ転送LSI500が通信インタフェース1及び2(213)と接続するバス2103及び2104が、PCIバスであるかPCI-Xバスであるかを設定する信号線である。モードセレクタ506は、例えば、ハイレベルの信号が供給されている間はバス2103及び2104がPCI-Xバスであるものとして、PCI-X規格に従って信号を送受信することができる。なお、モードセレクタ506は信号線以外にも、スイッチとしてもよい。また、プロセッサがローカルメモリに設定されている値に応じて、バス2103及び2104のバスの種類を特定するようにしてもよい。このように、データ転送LSI500は、PCI及びPCI-Xの両規格に従うバスに接続することができる。なお、PCI規格及びPCI-X規格以外の規格に従うバスに対応するようにしてもよい。

## [0030]

このように、データ転送LSI500は、複数の規格に従うバスに接続することができる。そのため、データ転送LSI500を搭載した記憶デバイス制御装置200は、技術の進歩に伴い新しい規格と古い規格とが混在するような状況においても、様々な規格に柔軟に対応することができる。

#### $[0\ 0\ 3\ 1]$

## ===データ転送処理1===

図3は、本実施の形態に係るデータ転送処理の流れを示す図である。図3は、マイクロプロセッサ1 (211) が通信インタフェース1 (213) に対してデータの取得を要求するリードコマンド (読み出しコマンド) を送信し、通信インタフェース1 (213) からデータを受信する流れを示している。図3に示すデータ転送処理は、例えば、データ転送LSI500がデータバッファ214に記憶されているデータをキャッシュメモリ230に転送する際、転送するデータ長やアドレス等のデータ転送に必要な情報を取得するときに、その情報を転送する処理として行われる。

#### [0032]

マイクロプロセッサ1(211)は、バス2101の使用権を獲得し、リードコマンド (READ-CMD) をブリッジA501に送信する (S3001)。ブリッジA501は、リードコマンドを受信し、スプリット応答 (SPLIT-RESP) をマイクロプロセッサ1 (211) に送信する (S3002)。マイクロプロセッサ1(211)は、スプリット 応答を受信すると、バス2101の使用権を解放する。従って、マイクロプロセッサ1(211)は、送信したリードコマンドに応じたデータが返信されるまで他の処理を行うことができる。図3において、期間31がマイクロプロセッサ1(211)が他の処理を行うことができる期間である。

#### [0033]

ブリッジA501は、リードコマンドをブリッジC503に転送する(S3003)。この

時点で、ブリッジA501は、他のコマンドを受け付けることができるようになる。ブリ ッジC503は、リードコマンドを受信すると、バス2103の使用権を獲得し、通信イ ンタフェース1(213)にリードコマンドを送信する(S3004)。

通信インタフェース1(213)はリードコマンドを受信すると、受信したリードコマ ンドに応じて、例えば、情報処理装置100から受信したデータ入出力要求のデータ長等 のリードデータ (READ-DATA) を作成する。通信インタフェース1 (213) は データを作成すると、リードデータをブリッジC504に送信する(S3005)。バス21 03が例えばPCIバス等のスプリットトランザクションを用いることができないバスで ある場合、通信インタフェース1(213)がリードデータを作成する間の(S3004)か ら(S3005)までの期間、ブリッジC503はビジー状態となる。また、ブリッジC50 3がバス2103の使用権を獲得しているため、バス2103もビジー状態となる。

## [0035]

ここで、ブリッジA501が通信インタフェース1(213)からのデータを待機する とすれば、図3の期間32の間もブリッジA501は他のコマンドを受け付けることがで きないビジー状態となってしまう。しかしながら、上記のブリッジA501は、期間32 の分だけコマンドを受け付けることができる期間を長くすることができる。本実施の形態 において、ブリッジA501はブリッジC503とブリッジD504との両方に接続して いるため、ブリッジC503がビジー状態であったとしても、ブリッジD504に対して コマンドを転送することができる。従って、ブリッジA501がコマンドを受け付けるこ とができる期間が長くなる。よって、データ転送LSI500がコマンドをより多く受け 付けることが可能となり、効率的なデータ転送LSI500の動作を図ることができる。

## [0036]

一方、ブリッジC503は、通信インタフェース1(213)からリードデータを受信 すると、バス2103をの使用権を解放し、リードデータをブリッジA501に転送する (S3006) 。

ブリッジA501は通信インタフェース1(213)から送信されたリードデータを受 信すると、バス2101の使用権を獲得し、マイクロプロセッサ1(211)にリードデ ータを送信し(S3007)、バス2101の使用権を解放する。

## [0037]

このようにして、マイクロプロセッサ211(プロセッサ)が通信インタフェース21 3(通信インタフェース部)にリードコマンド(読み出しコマンド)を送信すると、デー タ転送LSI500 (データ転送部) は、通信インタフェース213からリードデータの 応答であるリードデータを受信するよりも前に、マイクロプロセッサ211にスプリット 応答を送信することができる。従って、マイクロプロセッサ211は、通信インタフェー ス213から送信されるリードデータが到着するまで待機することなく、他の処理を行う ことができる。よって、マイクロプロセッサ211をより効率的に動作させることができ る。マイクロプロセッサ211の処理効率が向上すると、記憶デバイス制御装置200全 体としての処理効率も向上することになる。

#### [0038]

なお、本実施の形態において、マイクロプロセッサ1(211)がバス2101の使用 権を獲得する仕組みは、PCIバス等で一般的に用いられている調停回路を利用したもの を想定している。マイクロプロセッサ1 (211) は、例えば、ブリッジA501の備え る調停回路(不図示)に、バス2101を使用することを示すリクエスト信号を送信し、 調停回路がマイクロプロセッサ1(211)にバス2101を使用を許可する旨を示す応 答信号を送信する。これにより、ブリッジA501はバス2101に接続するデバイスに バス2101の使用権を与えることができる。また、ブリッジB502、ブリッジC50 3、及びブリッジD504も同様に調停回路を備え、夫々バス2102、バス2103、 及びバス2104の使用権を各バスに接続するデバイスに与えることができる。

#### [0039]

・次に、上述したデータ転送処理をタイミングチャートを用いて説明する。図 4 は、上記の処理における各信号を説明するタイミングチャートである。

## [0040]

ブリッジA 5 0 1がマイクロプロセッサ1 (2 1 1)にスプリット応答を返信し、マイクロプロセッサ1 (2 1 1)がバス2 1 0 1の使用権を解放した時点が、T 1である。 通信インタフェース1 (2 1 3)がリードデータをブリッジA 5 0 1に送信し(DAT A - T R A N S)、ブリッジA 5 0 1が受信したリードデータをマイクロプロセッサ1 (2 1 1)に送信し始めた時点がT 2である。

## (0041)

図4に示すように、 $T1 \sim T2$ の期間はバス2101の使用権が解放されている。 $T1 \sim T2$ の期間は、ブリッジA501はビジー状態であるため、マイクロプロセッサ1(211)は、ブリッジA501にコマンドを送信することはできない。しかしながら、マイクロプロセッサ1(211)はバス2101に接続する他のデバイスとやり取りをするなど、他の処理を行うことができる。そのため、より効率的なマイクロプロセッサ1(211)の動作を実現することができる。

## [0042]

なお、本実施の形態では、バス2103はPCIバスであるとしているが、PCI-Xバスとしてもよい。この場合、通信インタフェース1(213)はスプリット応答をブリッジC503に返信することができる。図5は、バス2103がPCI-Xバスであった場合の上記図3に示すデータ転送処理の流れを示す図である。

図5に示す処理の流れはほぼ図3に示す処理の流れと同様であるが、通信インタフェース1 (211) は、ブリッジC503から受信したリードコマンドに対して、スプリット 応答を送信する (S5001) 箇所が図3と異なる。ブリッジA501は、マイクロプロセッサ1 (211) が送信したリードコマンドに応じてスプリット応答を返信 (S3002) している。通信インタフェース1 (213) から受信したスプリット応答を、ブリッジC503がブリッジA501に、ブリッジA501がマイクロプロセッサ1 (211) に転送するようにすることもできる。しかしながら、その場合に比べ、本実施の形態によるデータ 転送処理では、図5に示すの期間51の分だけ、マイクロプロセッサ1 (211) が他の 処理を行うことができる期間が長くなっている。

## [0043]

#### ===データ転送処理2===

図 6 は、マイクロプロセッサ 1 (2 1 1 )が通信インタフェース 1 (2 1 3 )及び通信インタフェース 2 (2 1 3 )の両方からデータを読み出すときの処理の流れを示す図である。

#### [0044]

マイクロプロセッサ1 (211) は、バス2101の使用権を獲得し、通信インタフェース1 (213) に対するリードコマンド1 (READ-1) をブリッジA501に送信する (S6001)。ブリッジA501はスプリット応答をマイクロプロセッサ1 (211) に返信し (S6002)、マイクロプロセッサ1 (211) はバス2101の使用権を解放する。ブリッジA501は、ブリッジC503にリードコマンド1を転送する (S6003)。ブリッジC503は、バス2103の使用権を獲得し、受信したリードコマンド1を通信インタフェース1 (213) は、受信したリードコマンド1に応じたリードデータ1 (DATA-1) を作成する。

#### [0045]

その間に、マイクロプロセッサ 1 (2 1 1) は、再度バス 2 1 0 1 の使用権を獲得し、通信インタフェース 2 (2 1 3) に対するリードコマンド 2 (R E A D - 2) をブリッジ A 5 0 1 に送信する (S6005) 。ブリッジ A 5 0 1 はスプリット応答をマイクロプロセッサ 1 (2 1 1) に返信し (S6006)、マイクロプロセッサ 1 (2 1 1) はバス 2 1 0 1 の使用権を解放する。ブリッジ A 5 0 1 は、ブリッジ D 5 0 4 にリードコマンド 2 を転送する (S6007) 。ブリッジ D 5 0 4 は、バス 2 1 0 4 の使用権を獲得し、受信したリードコ

マンド2を通信インタフェース2 (213) に送信する (S6008) 。通信インタフェース2 (213) は、受信したリードコマンド2に応じたリードデータ2 (DATA-2) を作成する。

## [0046]

通信インタフェース1(213)は、リードコマンド1に応じたリードデータ1を作成すると、ブリッジC503にリードデータ1を返信する(S6009)。ブリッジC503は、リードデータ1を受信し、バス2103をの使用権を解放し、受信したリードデータ1をブリッジA501に転送する(S6010)。ブリッジA501は、バス2101の使用権を獲得し、受信したリードデータ1をマイクロプロセッサ1に送信し(S6011)、バス2101の使用権を解放する。

## [0047]

また、通信インタフェース 2 (2 1 3)が、リードコマンド 2 に応じたリードデータ 2 を作成すると、ブリッジ D 5 0 4 にリードデータ 2 を返信する(S6012)。ブリッジ D 5 0 4 は、リードデータ 2 を受信し、バス 2 1 0 4 の使用権を解放し、受信したリードデータ 2 をブリッジ A 5 0 1 に転送する(S6013)。ブリッジ A 5 0 1 は、バス 2 1 0 1 の使用権を獲得し、受信したリードデータ 1 をマイクロプロセッサ 1 に送信し(S6014)、バス 2 1 0 1 の使用権を解放する。

## [0048]

このようにして、マイクロプロセッサ1(211)と通信インタフェース1及び2(213)との間でデータが転送される。上記のデータ転送処理では、ブリッジA501は(S6002)においてマイクロプロセッサ1(211)にスプリット応答を返信し、ブリッジC503にリードコマンド1を転送し、ビジー状態ではなくなる。従って、マイクロプロセッサ1(211)は、再送信することなく、リードコマンド2をブリッジA501に送信(S6005)することができる。

## [0049]

図7及び図8は、上述した、マイクロプロセッサ1(211)が通信インタフェース1(213)及び通信インタフェース2(213)の両方からデータを読み出す際のデータ転送処理にかかる信号を説明する図である。

#### [0050]

図7は、ブリッジA501が、ブリッジC503及びブリッジD504と接続せず、直接バス2103及びバス2104と接続する形態における、上記データ転送処理を説明するタイミングチャートである。図8は、図6に示すデータ転送処理における信号を説明するタイミングチャートである。

### $[0\ 0\ 5\ 1]$

図7では、ブリッジA501は、リードコマンド1を通信インタフェース1 (213) に送信してからリードデータ1を受信するまでの間、ビジー状態 (BRIDGE-BUSY7101) となっている。そのため、マイクロプロセッサ1 (211) は、リードコマンド2をブリッジA501に送信することができず、再送信 (RETRY) を行う必要がある (S7001)。マイクロプロセッサ1 (211)が、リードコマンド2を再度送信し (S7002)、通信インタフェース2 (213)からのリードデータ2を受信し (S7003)、リードデータ2の受信が完了する時点がT7である。

#### [0052]

これに対し、図8では、ブリッジA501はマイクロプロセッサ1 (211) にリードコマンド1に対するスプリット応答を送信し (S8001) て、ビジー状態ではなくなる。そのため、マイクロプロセッサ1 (211) はリードコマンド2をブリッジA501に送信しても (S8002)、ブリッジA501はリードコマンド2を受信することができる。従って、マイクロプロセッサ1 (211) はリードコマンド2を再送信する必要がない。マイクロプロセッサ1 (211) が通信インタフェース2 (213) からのリードデータ2を受信し (S8003)、リードデータ2の受信が完了する時点はT8である。

#### [0053]

9/

プT7とT8とを比較しても明らかなように、本実施の形態におけるデータ転送LSI5 00によれば、データ転送処理にかかる時間が短縮されることになる。すなわち、本発明 によれば、ブリッジA501(第2のバスインタフェース部)は、リードコマンド1(第 1の読み出しコマンド)を受信すると、ブリッジC503 (第1のバスインタフェース部 )に送信するため、ビジー状態にならず、リードコマンド2 (第2の読み出しコマンド) を受信することができる。従って、マイクロプロセッサ1(211)(プロセッサ)は、 リードコマンド2(第2のコマンド)を送信するために待機することなく、データ転送L SI500(データ転送部)に第2のコマンドを送信することができる。また、マイクロ プロセッサ1(211)(プロセッサ)は、第1及び第2のコマンドを送信するとスプリ ット応答を受信するので、第1及び第2のコマンドに応じた読み出しデータを受信するま でバス2101を占有することなく、バス2101の使用権を解放することができる。よ って、バス2101の効率的な使用が可能となる。また、マイクロプロセッサ1 (211 )はリードデータを受信するまで待機することなく、他の処理を行うことができる。よっ て、マイクロプロセッサ211の効率的な利用が可能となる。これにより、マイクロプロ セッサ211の処理効率が上がり、多くの処理を行うことができるので、記憶デバイス制 御装置200全体の処理効率も向上する。

#### [0054]

図9に、バス2103及びバス2104がPCI-Xバスである場合のデータ転送処理の流れを示す。図9でも上記の図6と同様に、マイクロプロセッサ1(211)は、リードコマンド1に対するスプリット応答をブリッジA501から受信した後、再送信することなく、リードコマンド1に応じたリードデータ1を受信するよりも前に、リードコマンド2をブリッジA501に送信できるようになっている。

## [0055]

また、マイクロプロセッサ211から通信インタフェース213に対するコマンドの送信のみならず、通信インタフェース213からマイクロプロセッサ211に対するコマンドの送信においても同様に、データ転送処理にかかる時間を短縮することができる。

図10に、通信インタフェース1(213)が、マイクロプロセッサ1及び2(211)にリードコマンドを送信する際の、データ転送処理の流れを示す。なお、図10において、通信インタフェース1(213)が接続するバス2103は、PCI-Xバスであることとする。ここでも図9と同様に、ブリッジC503はリードコマンド1に応じたマンプロセッサ1(211)からのリードデータ1が応答されるよりも前にリードコマンド2を受信することができる。そのため、通信インタフェース1(213)は、リードコマンド2を再送信することができる。で、通信インタフェース1(213)は、リードコマンド2を再送信することなく、ブリッジC503に送信することができる。従って、通信インタフェース1(213)は、リードコマンド2の送信にかける時間を短縮することができる。よって、通信インタフェース1(213)は、リードコマンドの送信以外の処理に多く、時間をかけることが可能となり、これにより、通信インタフェース1(213)は情報処理装置100からより多くのデータ入出力要求を受信することができるので、記憶デバイスへのアクセスを行うことができる

#### [0056]

#### ===データ転送処理3===

図11は、マイクロプロセッサ1及び2(211)が通信インタフェース1(213)に対して、リードコマンド1を送信するときの処理の流れを示す図である。なお、以下の説明において、マイクロプロセッサ211、通信インタフェース213、ブリッジ501乃至504は、コマンドを送信するときにバスの使用権を獲得し、送信したコマンドに対する応答を受信するとバスの使用権を解放するものとする。

#### [0057]

マイクロプロセッサ 1 (2 1 1)は、通信インタフェース 1 (2 1 3)に対するリードコマンド 1 (R E A D - 1)をブリッジ A 5 0 1 に送信する(S11001)。ブリッジ A 5 0



『は、マイクロプロセッサ 1 (2 1 1 )にスプリット応答を送信し(S11002)、リードコマンド 1 をブリッジ C 5 0 3 に転送する(S11003)。

また、ほぼ同じタイミングで、マイクロプロセッサ 2 (2 1 1)が通信インタフェース 1 (2 1 3) に対するリードコマンド 2 (R E A D - 2) をブリッジ B 5 0 2 に送信する (S11004)。ブリッジ B 5 0 2 は、マイクロプロセッサ 2 (2 1 1) にスプリット応答を 送信し (S11005)、リードコマンド 2 をブリッジ C 5 0 3 に送信する (S11006)。

#### [0058]

ブリッジC503は、ブリッジA501からのリードコマンド1とブリッジB502からのリードコマンド2とをほぼ同時に受信するが、通信インタフェース1 (213) に同時に2つのコマンドを送信しないように調停を行う (S11007)。ここでブリッジC503は、例えば、リードコマンド1とリードコマンド2のどちらか先に受信した方を先に通信インタフェース1 (213)に送信するようにできる。図11において、リードコマンド1が先にブリッジC503に伝達されたものとする。ブリッジC503は、先に受信したリードコマンド1を通信インタフェース1 (213) に転送する (S11008)。通信インタフェース1 (213) は、受信したリードコマンド1に応じたデータ1 (DATA-1)を作成する。通信インタフェース1 (213) は、作成したデータ1をブリッジC503に送信する。なお、この時点で、ブリッジB502はリードコマンド2がブリッジC503に受理されていないため、ビジー状態となっている。

#### [0059]

ブリッジC503は、受信したデータ1をブリッジA501に転送する(S11009)とともに、リードコマンド2を通信インタフェース1(213)に送信する(S11010)。

ブリッジA 5 0 1は、ブリッジC 5 0 3からデータ1を受信すると、受信したデータ1をマイクロプロセッサ1 (2 1 1)に送信する(S11011)。

通信インタフェース1(213)は、リードコマンド2を受信すると、リードコマンド2に応じたデータ2(DATA-2)を作成する。通信インタフェース2(213)は、作成したデータ2をブリッジC503に送信する(S11012)。ブリッジC503は、受信したデータ2をブリッジB502に転送し(S11013)、ブリッジB502は受信したデータ2をマイクロプロセッサ2(211)に送信する(S11014)。

#### [0060]

このようにして、ブリッジC 5 0 3 は、同時に到達した 2 つのコマンドに対して調停を行い、2 つのコマンドの夫々を順番に通信インタフェース1 (2 1 3) に送信する。このとき、マイクロプロセッサ 2 (2 1 1) は、リードコマンド 2 を、再送信を行うことなくブリッジB 5 0 2 に送信することができる。そのため、マイクロプロセッサ 2 (2 1 1) は、スプリット応答を受信した後、データ 2 を受信開始するまでの間(図 1 1 における期間 1 1)、他の処理を行うことができる。従って、マイクロプロセッサ 2 1 1 の効率的な動作を図ることができる。また、ブリッジC 5 0 3 は、リードコマンド 1 に対応するデータ 1 を転送し、再度リードコマンド 2 を受信することなく、リードコマンド 2 を通信インタフェース 1 (2 1 3) に送信することができる。従って、マイクロプロセッサ 2 (2 1 1) がリードコマンド 2 を再送信する場合に比べ、通信インタフェース 1 (2 1 3) にリードコマンド 2 を早く到達させることができる。よって、データ転送処理にかかる時間が短縮される。

#### [0061]

この時間の短縮の様子を示したのが、図12及び図13のタイミングチャートである。図12は、ブリッジ C503が直接マイクロプロセッサ1及び2(211)からリードコマンドを受信し、マイクロプロセッサ2(211)がリードコマンド2を再送する場合の処理を説明するためのタイミングチャートである。図13は、上記図11の処理を説明するためのタイミングチャートである。

#### [0062]

図12において、マイクロプロセッサ2(211)(PCI\_Bバス)は、ブリッジC 503(BRIDGE)による調停の結果、リードコマンド2を送信することができず、



再送信(RETRY1201)を行う様子を示している。マイクロプロセッサ2(211)は、2度目のリードコマンド2の送信により、ブリッジC503にリードコマンド2を送信し、ブリッジC503は、リードコマンド2を通信インタフェース1(213)(PCI\_Cバス)に送信する。通信インタフェース1(213)からのリードデータ2(DATA-C)の受信を完了する時点が図12のT12である。これに対し、上記図11に示す処理では、マイクロプロセッサ2(211)が通信インタフェース1(213)からのリードデータ2の受信を完了する時点は、図13のT13である。T12とT13との比較から見ても明らかなように、本実施の形態のデータ転送処理によって、データ転送処理にかかる時間が短縮されていることが分かる。

## [0063]

図13において、ブリッジB502 (BRIDGE-B) は、マイクロプロセッサ2 (211) からのリードコマンド2に応じてスプリット応答を返信した後、ビジー状態となっている。しかしながら、マイクロプロセッサ2 (211) 及びバス2102 (PCI\_B) はビジー状態とならない。従って、マイクロプロセッサ2 (211) は、リードコマンド2に対応するデータ2が送信されてくるまでの間、他の処理を行うことが可能である。よって、マイクロプロセッサ211の効率的な運用が可能となり、また、データ転送LSI500のデータ転送にかかる時間が短縮され、データ転送処理の効率が図られ、記憶デバイス制御装置200全体としてのデータ転送効率も向上する。

#### $[0\ 0\ 6\ 4\ ]$

なお、図14は、通信インタフェース1(213)の接続するバス2103がPCI- X バスであった場合の、データ転送処理の流れを示す図である。図14においても、上記図11で説明した処理と同様に、ブリッジC503がリードコマンド1及び2の調停を行い、マイクロプロセッサ2(211)はビジー状態となることなく、他の処理を行うことができる。また、ブリッジC503は、リードコマンド1に対応するデータ1を受信し、データ1をブリッジA501に転送するとともに、マイクロプロセッサ2(211)から再度リードコマンドを受信することなく、リードコマンド2を通信インタフェース1(213)に送信することができる。

## [0065]

また、マイクロプロセッサ211から通信インタフェース213に対するコマンドの送信のみならず、通信インタフェース213からマイクロプロセッサ211に対するコマンドの送信においてもまったく上述の図11に示す処理と同様に、データ転送処理にかかる時間を短縮短縮することができる。図15に、通信インタフェース1及び2(213)からマイクロプロセッサ1(211)に対してリードコマンドが送信されるときの処理の流れを示す。図15に示す例おいても、通信インタフェース2(213)はビジー状態になることなく、他の処理を行うことができる。

#### [0066]

## ===データ転送処理4===

バス2103及びバス2104がPCI-Xバスである場合には、図15に示す上述したデータ転送処理により、データ転送処理の効率を向上することが可能である。そこで、本実施の形態に係る、バス2103及びバス2104がPCIバスである場合において、通信インタフェース1及び2(213)からマイクロプロセッサ1(211)に対してリードコマンドを送信した場合のデータ転送処理について説明する。なお、以下の説明において、マイクロプロセッサ211、通信インタフェース213、ブリッジ501乃至504は、コマンドを送信するときにバスの使用権を獲得し、送信したコマンドに対する応答を受信するとバスの使用権を解放するものとする。

#### [0067]

図16は、通信インタフェース1及び2(213)からマイクロプロセッサ1(211)に対してリードコマンドが送信される場合の処理の流れを示す図である。バス2103及び2104はPCIバスであるため、ブリッジC503やブリッジD504は、通信インタフェース1(213)や通信インタフェース2(213)にスプリット応答を返すこ



どができないことが、上述した図11に示す処理と異なる点である。

## [0068]

図16において、ブリッジA501がリードコマンド2(READ-2)を受信した(S16001)際、通常の調停回路と同様に、ブリッジD504に対して再送を要求するようにしてしまうと、通信インタフェース2(213)は、ブリッジA501がデータ1(DATA-1)をブリッジC503に転送した後に、再度リードコマンド2を送信する必要がある。しかしながら、ブリッジC503やブリッジD504は、通信インタフェース1(213)及び通信インタフェース2(213)からのリードコマンド1及び2を受信し、受信したリードコマンド1及び2を通信インタフェース213に再送させることがない。そのため、通信インタフェース213は、リードコマンドを再送するのにかかる時間を節約することができる。従って、通信インタフェース213の処理効率が向上し、記憶デバイス制御装置全体としてのデータ転送処理の効率も向上することができる。

#### [0069]

図17及び図18は、データ転送処理にかかる時間が短縮されたことを説明するための タイミングチャートである。

## [0070]

図17では、ブリッジA501(BRIDGE)が直接通信インタフェース1及び2(213)からリードコマンドを受信するときの信号を示している。図17において、ブリッジA501は、同時に受信するリードコマンドについて、調停(S17001)を行い、どちらか先に到着したものをマイクロプロセッサ1(211)に転送し、後に到着したものについてはリードコマンドを再送するように、リードコマンドの送信元に返信する。なお、図17において、ブリッジA501は、通信インタフェース213が常にビジー状態にならないように、リードコマンドに対するデータが作成できるまで、通信インタフェース213に再送(RETRY)するようにさせている。

## [0071]

ブリッジA501は、リードコマンド1を先にマイクロプロセッサ1(211)に送信し、スプリット応答を受信する。ブリッジA501は、通信インタフェース2(213)から再送されたリードコマンド2を受信する(S17002)が、マイクロプロセッサ1(211)からデータ1の応答を受信するため、先にデータ1を通信インタフェース1(213) に転送する。ブリッジA501は、マイクロプロセッサ1(121)から受信したデータ1を転送した後、リードコマンド2をマイクロプロセッサ1(211)に送信する(S17003)。

このようにして、通信インタフェース 2 (2 1 3) がリードデータ 2 の受信を完了した時点が T 1 7 である。

#### [0072]

これに対し、図18に示すデータ転送処理では、ブリッジA501が同時に受信するリードコマンドを調停し、リードコマンド1をマイクロプロセッサ1(211)に送信し、マイクロプロセッサ1(211)からスプリット応答を受信すると、通信インタフェース2(213)から再送されるリードコマンド2を待つことなく、リードコマンド2をマイクロプロセッサ1(211)に送信する。これにより、ブリッジA501は、マイクロプロセッサ1(211)がリードコマンド1に対応するデータ1を作成する間に、リードコマンド2もマイクロプロセッサ2(211)に送信しておくことができる。通信インタフェース2(213)がデータ2の受信を完了する時点は、図18においてT18である。T17とT18を比較しても明らかなように、データ転送処理にかかる時間は短縮されている。

#### [0073]

## ===記憶データの読み出し処理===

ここまでに説明したデータ転送処理は、マイクロプロセッサ211と通信インタフェース213との間で行われるデータの転送に用いられる処理である。ここで転送されるデータとは、主に、データバッファ214とキャッシュメモリ230との間でデータが転送さ



れる場合に必要な、データ長やアドレス等の情報である。しかしながら、上述したデータ 転送処理は、データバッファ214とキャッシュメモリ230との間でのデータ転送処理 に適用することも可能である。

## [0074]

以下に、データバッファ214とキャッシュメモリ230との間でデータが転送される 処理について説明する。

上述したように、記憶デバイス制御装置 200の備えるチャネル制御部 210は、情報処理装置 100からデータ入出力要求を受信し、データ入出力要求に応じて記憶ボリューム 300のアドレスやデータ長等を求め、記憶ボリューム 300へのアクセスを行うための I/Oコマンドを作成する。例えば、チャネル制御部 210が受信したデータ入出力要求がデータの読み出し要求である場合には、チャネル制御部 210は、読み出し対象となるデータをキャッシュメモリ 230から読み出し、情報処理装置 100に送信する。

#### [0075]

チャネル制御部210は、情報処理装置100との間で通信を行うデータをデータバッファ214に記憶する。例えば、記憶デバイス制御装置200が記憶ボリューム 300からデータを読み出す場合、データ転送LSI500は、キャッシュメモリ230に記憶されているデータをデータバッファ214に転送し、通信インタフェース213は、データバッファ214に記憶されているデータを情報処理装置100に送信する。

#### [0076]

図19は、通信インタフェース213がバッファコントローラ505を介してデータバッファ214からデータを読み出す処理の流れを説明する図である。

#### [0077]

通信インタフェース213は、バス2103の使用権を獲得し、バッファコントローラ505にリードコマンド(READ-CMD)を送信する。バッファコントローラ505は、スプリット応答を返信する。通信インタフェース213は、スプリット応答を受信すると、バス2103の使用権を解放する。バッファコントローラ505は、リードコマンドに応じて、記憶しているデータをバッファコントローラ505に送信する。バッファコントローラ505は、バッファコントローラ505は、バッファコントローラ505は、バス2103の使用権を獲得し、通信インタフェース213にデータを転送する。この一連の処理は上記図3に示したデータの転送処理と同様のものである。する、マイクロプロセッサ211と通信インタフェース213との間のみでなく、通信インタフェース213及びバス2103がビジー状態である期間を短縮し、より効率的な通信インタフェース213の動作と、効率的なバス2103の利用を図ることができる。

#### [0078]

図20は、通信インタフェース1(213)が情報処理装置100にデータを送信するために、マイクロプロセッサ1(211)からデータの転送に必要な情報(データ転送情報)を取得し、また、情報処理装置100に送信するデータをデータバッファ214から取得するときの処理の流れを示す図である。

#### [0079]

通信インタフェース1 (213) は、バス2103の使用権を獲得し、マイクロプロセッサ1 (211) からデータ転送情報を読み出すためのリードコマンド1 (READ-CTL) をブリッジC503に送信する。ブリッジC503はリードコマンド1を受信すると、スプリット応答を通信インタフェース1 (213) に返信する。

通信インタフェース1(213)は、スプリット応答を受信すると、バス2103の使用権を解放する。通信インタフェース1(213)は、続いてバス2103の使用権を獲得し、データバッファ214に対するデータの読み出しコマンドをバッファコントローラ505に送信する。バッファコントローラ505は、データの読み出しコマンドを受信すると、通信インタフェース1(213)にスプリット応答を返信する。通信インタフェース1(213)は、スプリット応答を受信し、バス2103の使用権を解放する。



・通信インタフェース1 (2 1 3) はこの時点で、マイクロプロセッサ1 (2 1 1) に対するリードコマンドと、データバッファ2 1 4 に対するデータ読み出しコマンドとの両方を送信したことになる。

## [0080]

## [0081]

また、バッファコントローラ505は、受信したデータ読み出しコマンドをデータバッファ214に転送する。データバッファ214は受信したデータ読み出しコマンドに応じて、記憶しているデータを読み出しデータとしてバッファコントローラ505に応答する。バッファコントローラ505は、バス2103の使用権を獲得し、受信した読み出しデータを通信インタフェース1(213)に送信し、バス2103の使用権を解放する。

#### [0082]

以上、本実施の形態に係る記憶デバイス制御装置200について説明したが、上述したデータ転送処理は、チャネル制御部210以外に適用することも可能である。例えば、ディスク制御部240が、マイクロプロセッサと、キャッシュメモリ230との間で通信を行うインタフェースと、キャッシュメモリ230と記憶デバイス300との間でデータを転送するデータ転送LSIとを備え、当該データ転送LSIが複数のブリッジを備えるようにして、マイクロプロセッサとインタフェースとの間でデータ転送を行う処理に、上述したデータ転送処理を適用することができる。

#### [0083]

以上、本実施の形態について説明したが、上記実施例は本発明の理解を容易にするためのものであり、本発明を限定して解釈するためのものではない。本発明は、その趣旨を逸脱することなく、変更、改良され得ると共に、本発明にはその等価物も含まれる。

## 【図面の簡単な説明】

## [0084]

- 【図1】本発明の一実施の形態による、情報処理システムの全体像を示すブロック図 である。
- 【図2】本発明の一実施の形態による、チャネル制御部210の内部構成を示す図である。
  - 【図3】本発明の一実施の形態による、データ転送処理の流れを示す図である。
- 【図4】本発明の一実施の形態による、図3に示すデータ転送処理の信号を説明する タイミングチャートである。
- 【図5】本発明の一実施の形態による、データ転送処理の流れを示す図である。
- 【図6】本発明の一実施の形態による、データ転送処理の流れを示す図である。
- 【図7】本発明の一実施の形態による、データ転送処理における信号を説明するフローチャートである。
- 【図8】本発明の一実施の形態による、データ転送処理における信号を説明するフローチャートである。
- 【図9】本発明の一実施の形態による、データ転送処理の流れを示す図である。
- 【図10】本発明の一実施の形態による、データ転送処理の流れを示す図である。
- 【図11】本発明の一実施の形態による、マイクロプロセッサ1及び2から通信イン



タフェース1に対するデータ転送処理の流れを示す図である。

【図12】本発明の一実施の形態による、ブリッジCが直接マイクプロセッサ1及び2からコマンドを受信するときのデータ転送処理における信号を説明するフローチャートである。

【図13】本発明の一実施の形態による、図11に示すデータ転送処理における信号を説明するフローチャートである。

【図14】本発明の一実施の形態による、バス2103がPCI-Xである場合のデータ転送処理の流れを示す図である。

【図15】本発明の一実施の形態による、通信インタフェース1及び2からマイクロプロセッサ1に対するデータ転送処理の流れを示す図である。

【図16】本発明の一実施の形態による、通信インタフェース1及び2からマイクロプロセッサ1に対するデータ転送処理の流れを示す図である。

【図17】本発明の一実施の形態による、ブリッジAが直接通信インタフェース213からコマンドを受信するときのデータ転送処理のおける信号を説明するフローチャートである。

【図18】本発明の一実施の形態による、ブリッジC及びブリッジDがブリッジAにコマンドを転送するデータ転送処理の一例における信号を説明するフローチャートである。

【図19】本発明の一実施の形態による、通信インタフェースとデータバッファとの間のデータ転送処理の流れを示す図である。

【図20】本発明の一実施の形態による、通信インタフェースとデータバッファとの間のデータ転送処理の流れを示す図である。

#### 【符号の説明】

## [0085]

| 1 0 0   | 情報処理装置   | 2 0 0   | 記憶デバイス制御装置 |
|---------|----------|---------|------------|
| 2 1 0   | チャネル制御部  | 2 1 1   | マイクロプロセッサ  |
| 2 1 2.  | ローカルメモリ  | 2 1 3   | 通信インタフェース  |
| 2 1 4   | データバッファ  | 2 1 6   | モードセレクタ    |
| 2 1 0 1 | バス       | 2 1 0 2 | バス         |
| 2 1 0 3 | バス       | 2 1 0 4 | バス         |
| 2 2 0   | 共有メモリ    | 2 3 0   | キャッシュメモリ   |
| 2 4 0   | ディスク制御部  | 2 5 0   | 接続部        |
| 3 0 0   | 記憶ボリューム  | 4 0 0   | SAN        |
| 5 0 0   | データ転送LSI |         |            |
| 5 0 1   | ブリッジA    | 5 0 2   | ブリッジB      |
| 5 0 3   | ブリッジC    | 5 0 4   | ブリッジD      |

【書類名】図面 【図1】



[図2]



【図3】



[図4]



[図5]



[図6]



【図7】



8/





【図9】



## 【図10】



【図11】





[図13]



【図14】



【図15】



[図16]



[図17]





【図19】



## 【図20】



## **【**書類名】要約書

【要約】

【解決手段】情報処理装置から送信されるデータ入出力要求を受信するチャネル制御部と、記憶デバイスの制御を行うディスク制御部と、キャッシュメモリとを備え、チャネル制御部は情報処理装置との間で通信を行う通信インタフェース部と、通信インタフェース部と第1のバスを介して接続し、データの転送を行うデータ転送部と、データ転送部と第2のバスを介して接続するプロセッサとを備える。通信インタフェース部は、プロセッサに対する読み出しコマンドをデータ転送部に送信する。データ転送部は第1のバスが第1の通信規約に従う場合はスプリット応答を通信インタフェース部に送信する。データ転送部は読み出しコマンドをプロセッサに送信する。プロセッサはスプリット応答をデータ転送部に送信し、受信した読み出しコマンドに応じた読み出しデータをデータ転送部に送信する。データ転送部は受信した読み出しデータを通信インタフェース部に送信する。

【選択図】 図2

特願2003-402996

出願人履歴情報

識別番号

[000005108]

1. 変更年月日

1990年 8月31日

[変更理由]

新規登録

住 所

東京都千代田区神田駿河台4丁目6番地

氏 名 株式会社日立製作所